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التبسيط فى الاوراكل 


تعريف قواعد البيانات :- 


قاعدة البيانات (عءaةطهtة0)‏ عبارة عن وعاء لمجموعة من البيانات 
تعكس نشاط منظمة أو شركة أو هيئة ذات نشاط محدد .مثلا نجد أن 
قاعدة بيانات الجامعة فيها كل البيانات المتعلقة بالطلاب و الأساتذة و 


المقررات الذراسة. 


متطلبات الكورس :- 


- Oracle data base 10g 


محتويات الكورس :- 
- الصيغة العامة لكتابة استعلام 
- استعلام و استخدام اسماء مستعارة 
- استعلام باستخدام العمليات الحسابية 
- استعلام باستخدام المعاملات المنطقية 
- استخدام اداة الدمج و اداة منع التكرار الحقول 
- استخدام الجمل الشرطية 
- ترتيب السجلات في الاستعلام 
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- عرض البيانات من اكثر من جدول 

د الأمشغلامات الفر دة 
دلاول + 

- انواع البيانات 

- الصيغة العامة لانشاء جدول 

- التعديل في الجدول 

حت الول 

- تغيير اسم الجدول 

- انشاء القيود علي الجداول 

- اضافة القيود علي الجداول 

- حذف القيود من الجداول 


- الصيغة العامة لاضافة بيانات الي جدول 
- تعديل بيانات في الجدول 
٤‏ - المستخدمين :- 
- تعديل اسم المستخدم 
- منح صلاحيات لمستخدم 
2 نزع صلاحیات من مستخدم 
- حذف المستخدم 
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مقدمة ت 
SQL‏ 
Structured query language‏ 


عبارة عن مجموعة من الأوامر التي تحتاجها البرامج وكذلك المستخدمين 


للوصول للبيانات »> المقصود بالاستعلام هو عرض بيانات مخزنة في 


فاعدة الساتات درن تغير محقم هذه البانات 


تنبیهات : 
- ال SQ‏ لا تتأثر بالاحرف الكبيرة و الصغيرة ( 1هنامa٣‏ 
(,Small‏ 


استرجاع البيانات )ع [ع؟:- 

select all - 

select many filed - 

Select condition- 

Select ( between , in ,„, like , null) 
Select (< , <= ,>, >=, =, 3ا‎ 
select ( and , or , not ) - 

order by - 

Group by &Having 

Function 


Join 
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Sub queries 


عرض كل الجداول في قاعدة البيانات 


Select * from all_tables; 


- عرض كل الحقول في جدول 
Select * from table_name;‏ 
متال : عرض بيانات جدول الموظفين 


Select * from emp; 


- عرض هيكل (البناء الداخلي) الجدول عطذإءيءمل 


Desc table_name; 


- عرض حقول معينة من جدول 
ت الل ارا ا اد عا ت ا الدرل 


Select ename, sal from emp; 


- الاسماء المستعارة وميهناج 
نستخدمها لاعطاء الحقل اسم اسمه الموجود في الجدول و لدينا عدة طرق 
ذلك 

- باستخدام یھ 


space باستخدام‎ - 
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عرض رقم الموظف و اسمه و راتبه مع اعطاء اسماء مستعارة للحقول 


Select empno "employee number" , ename as name ,sal 
salary from emp ; 


-استخدام || , distinct‏ 
تستخدم || للدمج 


Select ename , deptno , ename jj "work in " || deptno from 
emp; 


عبlرö DISTINCT‏ 
تستخدم هذه العبارة لمنع تكرار السجلات 


Select distinct deptno from emp); 


Select ename , Job , sal , sal*12 from emp 
قمنا باسترجاع اسم الموظف و وظيفته و راتبه و راتبه في السنة‎ 


order by - 


kاعاc‏ مع ترتیب الحقول تصاعدیا حسب رقم الادارة 


Select enmae „job , deptno from emp 
Where job='clerk' 
Order by deptno; 
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معاملات المقارنة (=! ,== وکح ,=< و<(:- 


عرض اسماء ووظائف و رواتب الموظفين الذين رواتبهم اكبر من او 
تساوي 5000 


Select ename , job , sal from emp where sal>=5000 


عرض اسماء ووظائف و رواتب الموظفين الذين رواتبهم اصغر من او 
تساوي 5000 


Select ename , job , sal from emp where sal<=5000 


عرض اسماء ووظائف و رواتب الموظفين الذين رواتبهم لا يساوي 5000 


Select ename , Job , sal from emp where sal !=5000 


عرض اسماء ووظائف و رواتب الموظفين الذين رواتبهم تساوي 5000 


Select ename , Job , sal from emp where sal =5000 


معاملات المقارنة -:(between , in , like , null)‏ 
عرض اسماء الموظفين و رواتبهم الذين رواتبهم بين 5000 , 2000 


Select ename , sal from emp where sal between 2000 and 
5000 


(7788, 1566,7902) 
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Select empno , ename from emp where empno in (7902, 
7566,7788); 


Like :- 

تستخدم للبحث عن نص معين داخل الحقل 

(%۸) يعني مطابقة النص الذي ينتهي بحرف ۸ 

((۸%) يعني مطابقة النص الذي يبدا بحرف ۸ 

(%۸%) يعني مطابقة النص الذي به الحرف ۸ 

عرض اسماء الموظفین الذین تبداً اسمائھم بحرف ۴ 

Select ename from emp where ename like 'F%' ; 


عرض اسماء الموظفين الذين يكون الحرف الثاني ۴ 


Select ename from emp where ename like '_F%'; 


Null* 
تعني قيمة خالية او فارغة و لا تعني صفر‎ 
عرض اسم و رقم المدير للموظفين الذين ليس لهم مدير‎ 


Select ename, mgr from emp where mgr 1s null ; 


*المعاملات المنطقية (٤0د‏ , إ0 , (and‏ 

الرابط لمعه يرجع قيمة عںع] اذا كانت الجملتين صحيحتين 
الرابط إه يرجع قيمة عںع] اذا كانت احدي الجملتين صحيحة 
الرابط 0م تنفي النتيجة 
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٠ امثلة‎ 

عرض رقم و اسم و وظيفة و راتب الموظفين الذين رواتبهم اكبر من او 
تساوي 1000 و وظيفتهم c1)‏ 

Select empno , ename , Job , sal from emp 


Where sal >=1000 and job ='clerk' ; 


عرض رقم و اسم و وظيفة و راتب الموظفين الذين رواتبهم اكبر من او 
تساوي 1000 او وظیفتهم )م1 


Select empno , ename , Job , sal from emp 


Where sal >=1000 or Job ='clerK' ; 


عرض رقم و اسم و وظيفة و راتب الموظفين الذين رواتبهم ليست بين 
3000 , 1000 


Select empno , ename , Job , sal from emp 


Where sal not between 1000 and 3000 ; 


دوال الصف الواحد : دوال التجميع 
Sum‏ 
تستخدم لايجاد مجمو ع القيم 
Min‏ 
تستخدم لايجاد اقل قيمة 
of APage‏ ۲ 
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Max 

تستخدم لايجاد اكبر قيمة 
avg‏ 

تستخدم لايجاد المتوسط للقيم 
Count‏ 

تستخدم لاحساب او عد القيم 


Select sum (sal) , max (sal) „, min (sal) , avg(sal) „count 
(ename) from emp ; 


اي قم بارجاع مجموع مرتبات الموظفين و اعلي راتب و اقل راتب و 


group by *‏ 
تستخدم هذه العبارة لتقسيم البيانات الي مجموعات علي حسب عمود معین 
Select deptno , max(sal) from emp group by deptno);‏ 


اي قم باسترجاع رقم الادارة و اعلي راتب في كل ادارة 


* لا يمكن استخدام ١٥ط‏ سمع الدوال التجميعية بل نستخدم عمز۷ه! 


Select deptno , avg(sal) from emp group by deptno 
having avg(sal)>2000; 
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Join 
هو الربط بين الجداول‎ 

Equijoin - 
Nonequijoin 
Outer join - 
Self Join - 


الربط مزمز هو عبارة عن ربط بين جدولين او اكثر للحصول علي بيانات 
من الجداول 


النوع الاول ,زنس وء الربط التساوي :- 
يتم الربط بين جدولین او اكثر عن طريق عمودين متساويين 


Select emp.empno,emp.ename , emp.deptno ,dept.loc 
from emp , dept where emp.deptno=dept.deptno; 


استرجاع رقم الموظف و اسمه و رقم الادارة من جدول الموظفين و موقع 
الادارة من جدول الادارات بشرط رقم الادارة في جدول الموظفين يساوي 
رقم الادارة في جدول الادارات 


النوع الثاني ہذەزe4}ui non‏ :- 
في هذا النوع لاتوجد علاقة مباشرة بين جدولين المراد ربطهما 
Select e.ename,e.sal , s.grade from emp e , salgrade s‏ 


Where e.sal between s.losal and s.hisal ; 
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اي قمنا بعرض اسماء الموظفين و رواتبهم من جدول الموظفين و عرض 
الفئات لكل راتب من جدول الفئات بشرط الرواتب بين اقل راتب و اعلي 
راتب من جدول الفئات 


الربط الخارجي داز ٣ع‏ )ا0 :- 
نستخدم هذا النوع من الربط عندما توجد بيانات في احد الجداول و لكنها لا 
تظهر في الربط بالتساوي بين الجدولين 


Select e.empno, e.ename, d.deptno , d.dname from emp 
e,dept d 


Where e.deptno(+)=d.deptno; 


عرض ارقام الموظفين و اسمائهم من جدول الموظفين و ارقام الادارات و 
اسمائهم من جدول الادارات 


النوع الرابع ہذهز fاعء‏ :- 


Select worker.empno ,worker.enmae , manager.ename 
manager 


From emp worker ,emp manager 


Where worker.mgr=manager.empno ; 


sub queries 


هي وجود عدة استعلامات في جملة ال se]‏ 


Select ename from emp where sal > (select sal from emp 
where enmae = 'JAMES’); 
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اي قم باسترجاع اسماء الموظفين من جدول الموظفين بشرط الراتب 


: انواع الاستعلامات الفرعية‎ 
Single row subquery- 


Multiple row subquery- 
Multiple column subquery- 


الاستعلامات الفرعية احادية صف 

هي استعلامات نتيجة تنفيذدها صف واحد ( =>, کح کح <( 
Select ename , sal , deptno from emp‏ 

where deptno= (select deptno from emp where 
ename ='KING'); 

اي قم بعرض اسماء و رواتب و ارقام ادارات الموظفين في نفس 
ادارة الموظف king‏ 


الاستعلامات الفرعية متعددة الصفوف 

هي استعلامات نتيجتها اكثر من صف (1۸ , رمه , 11ج) 

قم بعرض اسماء و رواتب و ارقام ادارات الموظفين الذين ياخذون 
رواتب مساوية لاقل راتب في كل ادارة 

Select ename , sal , deptno from emp where sal in 
(select min(sal) from emp group by deptno ); 


استعلام متعدد الاعمدة 


قم بعرض الاصناف التي لها نفس رقم المنتج و الكمية للاصناف 
داخل الطلب رقم 605 
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Select order_1d , product_1d , quantity from item 
where (product_1d , quantity) 1n (Select 
product_1d,quantity from item where 
order_1d=605); 


اضافة البيانات 

الصيغة العامة لاضافة بيانات في جدول :- 

Insert into table_name values ( value_felid ,value_felid 
ا‎ 

مثال ۰- 

اضافة بيانات في جدول الادارات 

Insert into dept values ( 10,'sales' ,؛khartoum’);‎ 


قمنا باضافة سجل يحتوي علي 10 لرقم الادارة و وع اهي لاسم الادارة و 
khart) um‏ لموقع الادارة 


طرق اضافة البيانات لجدول :- 
الطريقة الاولي : اضافة لكل الحقول في جدول 


نفس المثال السايق اي قمنا باضافة قيم لكل الحقول الموجودة في الجدول 


Insert into dept values ( 10,'sales' ,khartoum’); 


الطريقة الثانية : اضافة لحقول معينة في جدول 
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Insert Into dept (dept_no , dept_name ) values ( 10,'sales' 
); 
قمنا باضافة قيم في حقل رقم الادارة و اسم الادارة فقط‎ 


حذف البيانات في جدول :- 

اي حذف سجلات من جدول في قاعدة البيانات 

Delete from dept; 

هتا فما بحذف كل الحقر ل من جذرل الاد ارات ٠اا‏ اذا اردتا خذف حول 
معينة نستخدم جملة الشرط عإعآاسw‏ 


Delete dloc from dept; 
قمنا بحذف حقل اسم الادارة من جدول الادارة‎ 


ملاحظة : عند حذف بيانات جدول لا يأثر ذلك علي الجدول اي يكون 


Update table 


Set Column= value ; 
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تعديل لزيادة رواتب الموظفين في جدول 1۶ _٤E‏ ا5۵ بحیث يزيد مرتب كل 
واحد عن ٠٠١‏ جنیه 
المستخدمين :- 


Update sal_emp set sal = sal+100; 


الجداول :- 
ما هو الجدول 


- انواع البيانات 

- الصيغة العامة لانشاء جدول 
- التعديل في الجدول 
E‏ 

- تغيير اسم الجدول 

- انشاء القيود علي الجداول 
أضاة ارد ط الذرل 
حت القر د هر الكارل 


الشروط الواجب توافرها عند اختيار اسم الجداول أو أسماء الأعمدة 


ميجب أن يبدأ اسم الجدول أو اسم العمود بحرف. 

#يجب أن لا يزيد طول الاسم عن )۳١(‏ حرفاً. 

همن الممكن أن يتكون من حروف كبيرة وصغيرة وأرقام ورموز خاصة 
مثل (_› $» #). 

ميجب ألا يتكرر اسم الجدول أكثر من مرة داخل قاعدة البيانات الواحدة. 
ميجب ألا يتكرر اسم عمود أكثر من مرة داخل الجدول الواحد. 
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يجب أن لا يكون من الأسماء المحجوزة لأوراکل مثل ( ۴۸0M,‏ 
.(SELECT, ..‏ 
يفضل أن يكون اسم الجدول له معنى بحيث يعبر عن نوع بيانات الجدول. 


انواع البيانات : 

Number 

تستخدم مع البيانات الرقمية 
Varchar‏ 

تستخدم مع البيانات الحرفية 
Varchar2‏ 

تستخدم مع البيانات الحرفية 
Date‏ 

تستخدم مع بيانات التاريخ 
Long‏ 

تستخدم مع البيانات النصية ذات حجم كبير يصل الي ۲ جيجا بايت 
Blob‏ 

يستخدم مع البيانات الثنائية 


الصيغة العامة لانشاء جدول : 


Create table table name (filed data type (length,....); 


في البداية نكتب انشاء ثم كلمة م[طه] جدول ثم اسم الجدول و الحقل و نوع 
اتات لك انحل د طر ل الل ار ححب: 


مثال 
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و e‏ و و و و و و و و و و کے و و و و کے وی و س و و و ری 


Create table student (sno number(10),sname 


varchar2(30),saddress varchar2(30)); 


قمنا بانشاء جدول اسمه الطالب لديه عدة حقول حقل رقم الطالب و نوعه 
رقمي و طوله ٠١‏ تم حقل اسم الطالب نوع بياناته حرفي و طوله ۰ و 


حقل عنوان الطالب و نوعه حرفي و طول هذا الحقل ٠١‏ 


لعرض هيكل الجدول 


Desc student ; 


- حذف الجدول 
لحذف البيانات نستخدم الامر pهإل‏ 
Drop table dept ;‏ 
يقوم هذا الامر بحذف الجدول من قاعدة البيانات 


لتغير اسم جدول 
عمصهen R‏ اسم الجدول القديم م] اسم الجدول الجديد 
قم بتغییر اسم جدول ٤ع‏ نں)ء إلى ای 


Rename student to St; 


تعدیل فی جدول :- 
هناك طريقتين لتعديل بيانات في جدول :- 
الطريقة الاولي : اضافة حقل جدول 
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و و و و و و کے و و و س و کے و و mm‏ و و کے وی و mm‏ و و وی و و و کے و و و و وی س و 


Alter table dept add ( d_date date );‏ 
قمنا باضافة حقل التاريخ لجدول الادارات وهو لم يكن موجودا من قبل 


Alter table modify ( d_date number(10) );‏ 
قمنا بتعديل نوع بيانات حقل التاريخ من نوع تاريخي الي نوع رقمي 


الطريقة الثالثة : حذف حقل من الجدول 
Alter table dept drop ( d_date date );‏ 
قمنا بحذف حقل التاريخ من جدول الادارات 


انشاء مستخدم 

الصيقة العامة العامة لانشاء مستخدم 

Create user user _name 1dentified by password; 
-۰ مثال‎ 

Create user noon 1dentified by aaa; 

هنا قمنا بانشاء مستخدم باسم 0۸٠0م‏ و كلمة السر ههج 


لتعديل كلمة المرور : 
نكتب تعديل ثم اسم المستخدم ثم رط لعانا مل ثم كلمة المرور الجديدة 


Alter user noon 1dentified by nnn; 
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بعد ما انشائنا مستخدم نعطيه الصلاحيات 

Grant connect to noon; 

هنا منحنا المستخدم نون صلاحية الاتصال 

Grant select to noon; 

قمنا بمنح صلاحيات الاستعلام من المستخدم نون 
Grant dba to noon;‏ 

في الامر السابق منحنا نون صلاحية مدير قاعدة البيانات 


نزع الصلاحيات 
revoke dba from noon ;‏ 


هنا قمنا بنزع صلاحية مدير فاعدة البيانات من المستخدم نون 


حذف مستخدم :- 

لحذف مستخدم من قاعدة البيانات نستخدم هذا الامر 
drop user noon;‏ 

لحذف المستخدم نون 
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